﻿using System.Text;
using System.Text.RegularExpressions;

namespace JNPF.Utils
{
    /// <summary>
    /// 防止Script注入
    /// 版 本：V3.0.0
    /// 版 权：引迈信息技术有限公司（https://www.jnpfsoft.com）
    /// 作 者：JNPF开发组
    /// </summary>
    public class AntiScriptInject
    {
        /// <summary>
        /// 静态实例
        /// </summary>
        public static AntiScriptInject Instance
        {
            get { return new AntiScriptInject(); }
        }
        /// <summary>
        /// 是否安全
        /// </summary>
        /// <param name="input">输入</param>
        /// <returns></returns>
        public bool IsSafetyScript(string input)
        {
            var isOk = Regex.IsMatch(input, this.GetRegexString);
            if (isOk == false)
            {
                return true;
            }
            else
            {
                return false;
            }
        }
        /// <summary>
        /// 获取正则表达式
        /// </summary>
        private string GetRegexString
        {
            get
            {
                StringBuilder strText = new StringBuilder();
                strText.Append("<(.|\n)+?>");//包含HTML标签
                return strText.ToString();
            }
        }
    }
}
